## **CS311 Project 3: Building a Simple MIPS Simulator**

Due 11:59pm, November 21<sup>st</sup>, 2019 TA: Sun Ho Lee

### 1. Overview

This third project is to build a 5-stage pipelined simulator of a subset of the MIPS instruction set. The simulator loads a MIPS binary into a simulated memory, and executes the instructions. Instruction execution will change the states of registers and memory. The simulator will need to detect and behave accordingly for any data or control hazards. Please also read the README.md file provided in the repository.

If you have any questions related to the project, please ask them on the Q&A board. The assigned TA will answer them whenever possible.

### 2. Required Pipeline Implementation

In this project you will need to implement the 5 stage MIPS pipeline that you have learned in class into your MIPS simulator (from Project 2).

### 2.1 Pipeline Stages

We will use a simple 5-stage pipeline for this project:

- 1. IF: fetch a new instruction from memory.
- 2. ID: decode the fetched instruction and read the register file
- 3. EX: execute an ALU operation
  - a. Execute arithmetic and logical operations
  - b. Calculate the addresses for loads and stores
- 4. MEM: access memory for load and store operations
- 5. WB: write back the result to the register

Between the adjacent pipeline stages, pipeline registers (or pipeline latches) must be modeled. All communication between stages must be conducted using the pipeline registers.

### 2.2 Register File

The register file is used in both the ID stage and the WB stage, however the WB writes the register file at the first half of a cycle and ID reads on the second half of a cycle resulting in no structural hazards in the register file.

### 2.3 Memory Model

We assume an ideal dual-ported memory, which allows both a read at IF, and a read/write at MEM simultaneously within the same cycle. There is no structural hazard for the memory accesses from IF and MEM. You can assume the memory locations where instructions are stored are never updated. Therefore, you do not need to consider the case where a store at MEM updates the same address fetched at IF at the same cycle.

### 2.4 Forwarding

The pipelined architecture must support data forwarding from MEM/WB-to-EX, EX/MEM-to-EX. With the forwarding support, data hazard only occurs for the data dependency from a load to the

succeeding instruction which uses the value in the EX stage. MEM/WB-to-MEM is also supported.

#### 2.5 Control Hazard

For unconditional jumps, you will always add a one-cycle stall to the pipeline (J, JAL, JR). For JAL, assume there is a single delay slot after JAL instruction. Therefore, when calling the JAL instruction save the PC+4 value into the R31 (as with project 2). In this project, the binaries and assembly files have been modified to have a nop instruction (in the form of add \$0, \$0, \$0) right after every JAL instructions.

For the sake of simplicity, don't bother executing the delay slot. When the jump decision is made from the ID stage, just flush the IF stage.

For conditional branches (BEQ, BNE), your simulator must support the static branch predictor which always predicts branches **not taken**. The actual evaluation of the branch will be executed by the ALU and thus the branch result will be ready at the end of the EX stage. However, **the actual flushing will take place at the beginning of the MEM stage.** A correct branch (not taken) will not incur any stalls; a miss prediction will cause 3 cycle stall (flushing of the EX, IF, and ID of the newer instructions). Also, if the branch decision has dependencies on prior executions, stall the execution at the appropriate stage.

### 2.6 Stopping the Pipeline

The simulator must stop after a give number of instructions finishes the WB stage. At cycle 1, the first instruction is fetched from the memory. If the last instruction is in the WB stage at cycle N, the final CYCLE count is N.

### 3. Pipeline Register States

You need to add pipeline register states between stages. The followings are possible register contents, but you need to add more states.

IF\_ID.Instr : 32-bit instruction
IF\_ID.NPC : 32-bit next PC (PC+4)

ID\_EX.NPC: 32-bit next PC
ID\_EX.REG1: REG1 value
ID\_EX.REG2: REG2 value
ID\_EX.IMM: Immediate value
EX\_MEM.ALU\_OUT: ALU output

EX\_MEM.BR\_TARGET: Branch target address

MEM\_WB.ALU\_OUT: ALU output
MEM\_WB.MEM\_OUT: memory output

You must carefully design what fields are necessary for each pipeline register, and explain them in "README" file in your submission. You must explain what each field means.

### 4. Forking and Cloning your Repository

### 4.1 Forking the TA's Repo

(1) Go to the following page: <a href="http://cs311.kaist.ac.kr:10080/cs311">http://cs311.kaist.ac.kr:10080/cs311</a> projects/project3-mips-pipelined-simulator.



This page is the TA's repository!!!

## Important!!!

\*Don't make a branch in this repository (TA's repository). If you make your branch in this repository, then other students can see your code. We saw some students made their own branch in TA's repository during Project1 and Project2. So please don't make branches in the TA's repository.

- (2) Click the fork button just like Project 1 and Project 2.
- (3) Now select your username and the repo will be forked.

cs311\_projects > project3-mips-pipelined-simulator > Fork project

### Fork project

A fork is a copy of a project. Forking a repository allows you to make changes without affecting the original project.

#### Select a namespace to fork the project



- (4) Your own repo will have the following URL: http://cs311.kaist.ac.kr:10080/[Your student ID]/project3-mips-pipelined-simulator
- 4.2 Cloning your own repository to your local machine

\*We highly recommended to work on your allocated server throughout this class

From the website of your team repo copy the SSH or HTTPS URL of the git repository the SSH URL will look something like the following: ssh://git@cs311.kaist.ac.kr:10022/[Your student ID]/project3-mips-pipelined-simulator.git

Change directory to the location you want to clone your project and clone! \$ git clone ssh://git@cs311.kaist.ac.kr:10022/[Your student ID]/project3-mips-pipelined-

simulator.git

Be sure to read the README.md file for some useful information.

### 5. Simulator Options and Output

### 5.1 Options

\$ ./cs311sim [-m addr1:addr2] [-d] [-n num\_instr] inputBinary

- -m: Dump the memory content between addr1 to addr2
- -d: Print the register file content every cycle. Prints memory content every cycle if -m option is enabled.
- -n: number of instructions simulated
- -p: print the PCs of of the instructions in each pipeline stage at every cycle. Prints a blank if the stage of the pipeline is stalled/empty.
  - ex) CYCLE 5:0x00400010|0x0040000c|0x00400008|0x00400004|0x00400000

### **5.2 Reference output**

We will be providing a reference output (located in the sample\_output directory) so that you may compare the execution of your simulator to the reference.

The TA's answer *may* contain some incorrect executions. If you do find any upon your debugging and comparing, please do drop us an e-mail of the expected behavior, and the actual behavior shown by the TA's answer. We'll check it out and fixed reference outputs.

### **6. Grading Policy**

Grades will be given based on the examples provided for this project provided in the `sample\_input` directory. Your simulator should print the exactly same output as the files in the `sample\_output` directory.

We will be automating the grading procedure by seeing if there are any difference between the files in the `sample output` directory and the result of your simulator executions.

Please make sure that your outputs are identical to the files in the sample\_output directory.

You are encouraged to use the `diff` command to compare your outputs to the provided outputs.

\$ ./cs311sim -p sample\_input/example01.o > my\_output \$ diff -Naur my\_output sample\_output/example01

If there are any differences (including whitespaces) the diff program will print the different lines. If there are no differences, nothing will be printed.

Being "Correct" means that every digit and location is the same to the given output of the example. If a digit is not the same, you will receive **0 score** for the example.

## Important!!!

\*Before you use 'make test' command, type 'make clean' first to eliminate all other execution files.

If you want to check all test cases, you can use 'make test' command as same as Project1 and Project2.

\$ make clean \$ make test

### 7. Submission (Important!!)

### 7.1 Make sure your code works well on your allocated Linux server.

In fact, it is highly recommended to work on your allocated server throughout this class. Your project will be graded on the same environment as your allocated Linux server.

# 7.2 Add the 'submit' tag to your final commit and push your work to the gitlab server.

The following commands are the flow you should take to submit your work.

\$ git tag submit \$ git push \$ git push --tags

If there is no "submit" tag, your work will not be graded so please remember to submit your work with the tag.

If you do not `push` your work, we will not have the visibility to your work. Please make sure you push your work before the deadline.

### 8. Late Policy

You will lose **50%** of your score on the **first day** (Nov 22<sup>nd</sup> 0:00~23:59). We will **not accept** works that are submitted after then.

**Be aware of plagiarism!** Although it is encouraged to discuss with others and refer to extra materials, copying other students or opened code is strictly banned.

The TAs will compare your source code with open source codes and other student's code. If you are caught, you will receive a penalty for plagiarism.

If you have any requests or questions regarding administrative issues (such as late submission due to an unfortunate accident, GitLab is not working) please send an e-mail to the TAs(cs311 ta@calab.kaist.ac.kr).

### 9. Updates/Announcements

If there are any updates to the project, including additional tools/inputs/outputs, or changes, we will post a notice on the Notice board of KLMS, and will send you an e-mail using the KLMS system. Frequently check your KLMS linked e-mail account or the KLMS notice board for updates.